<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="${package.Mapper}.${table.mapperName}">
<#if enableCache>
    <!-- 开启二级缓存 -->
    <cache type="org.mybatis.caches.ehcache.LoggingEhcache"/>
</#if>
    <#if baseResultMap>
    <!-- 通用查询映射结果 -->
    <resultMap id="BaseResultMap" type="${package.Entity}.${entity}">
            <#list table.fields as field>
                <#if field.keyFlag><#--生成主键排在第一位-->
        <id column="${field.name}" property="${field.propertyName}"/>
                </#if>
            </#list>
            <#list table.commonFields as field><#--生成公共字段 -->
        <result column="${field.name}" property="${field.propertyName}"/>
            </#list>
            <#list table.fields as field>
                <#if !field.keyFlag><#--生成普通字段 -->
        <result column="${field.name}" property="${field.propertyName}"/>
                </#if>
            </#list>
    </resultMap>

    </#if>
    <#if baseColumnList>
    <!-- 通用查询结果列 -->
    <sql id="BaseColumnList">
        <#list table.fields as field>
        <#noparse>${</#noparse>alias<#noparse>}</#noparse>.${field.name}<#if field_has_next>,</#if>
        </#list>
    </sql>
    </#if>

    <!-- 根据条件分页查询${table.comment}信息SQL语句 -->
    <sql id="${entity}ListSQL">
        SELECT
        <include refid="BaseColumnList">
            <property name="alias" value="a"/>
        </include>
        FROM ${table.name} a
        <where>
            <!-- 员工姓名模糊匹配 -->
            <if test="${entity?uncap_first}.name != null and ${entity?uncap_first}.name != ''">
                AND a.name like CONCAT('%',<#noparse>#{</#noparse>${entity?uncap_first}.name<#noparse>}</#noparse>,'%')
            </if>
            <!-- 入职时间 -->
            <if test="dates != null and dates.length == 2 ">
                AND a.create_time BETWEEN <#noparse>#{</#noparse>dates[0]<#noparse>}</#noparse> AND <#noparse>#{</#noparse>dates[1]<#noparse>}</#noparse>
            </if>
        </where>
    </sql>

    <!-- 根据条件分页查询${table.comment}信息 -->
    <select id="get${entity}ListByPage" resultMap="BaseResultMap">
        <include refid="${entity}ListSQL"></include>
    </select>
</mapper>
